简介
MPAndroidChart是PhilJay大神给Android开发者带来的福利。MPAndroidChart是一个功能强大并且使用灵活的图表开源库,支持Android和IOS两种,这里我们暂时只关注Android版本。
Wiki
https://github.com/PhilJay/MPAndroidChart/wiki
Javadoc
https://jitpack.io/com/github/PhilJay/MPAndroidChart/v3.0.0-beta1/javadoc/
今日之图~BarChart
先看图,压压惊
布局文件
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17
| <?xml version="1.0" encoding="utf-8"?> <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:tools="http://schemas.android.com/tools" android:layout_width="match_parent" android:layout_height="match_parent" android:paddingBottom="@dimen/activity_vertical_margin" android:paddingLeft="@dimen/activity_horizontal_margin" android:paddingRight="@dimen/activity_horizontal_margin" android:paddingTop="@dimen/activity_vertical_margin" tools:context="mapdemo.example.com.mpandroidchartdemo.MainActivity"> <com.github.mikephil.charting.charts.BarChart android:id="@+id/barchart" android:layout_width="match_parent" android:layout_height="match_parent" android:text="Hello World!" /> </RelativeLayout>
|
对于Chart,可以采用布局文件添加方式,也可以采用代码添加方式。
代码
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61
| public class MainActivity extends AppCompatActivity {
@Bind(R.id.barchart) BarChart barchart;
private Random random;
@Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); ButterKnife.bind(this); random = new Random(); initBarChart(); }
private void initBarChart() { ArrayList<BarEntry> yVals = new ArrayList<>(); ArrayList<BarEntry> yVals2 = new ArrayList<>(); ArrayList<BarEntry> yVals3 = new ArrayList<>(); ArrayList<String> xVals = new ArrayList<>();
for (int i = 0; i < 12; i++) { xVals.add((i + 1) + "月"); yVals.add(new BarEntry(random.nextInt(10000), i)); yVals2.add(new BarEntry(random.nextInt(10000), i)); yVals3.add(new BarEntry(random.nextInt(10000), i));
}
BarDataSet barDataSet = new BarDataSet(yVals, "小明每月支出"); barDataSet.setColor(Color.RED);
BarDataSet barDataSet2 = new BarDataSet(yVals2, "小花每月支出"); barDataSet2.setColor(Color.GREEN);
BarDataSet barDataSet3 = new BarDataSet(yVals3, "小蔡每月支出"); barDataSet3.setColor(Color.YELLOW);
ArrayList<IBarDataSet> threebardata = new ArrayList<>(); threebardata.add(barDataSet); threebardata.add(barDataSet2); threebardata.add(barDataSet3);
BarData bardata = new BarData(xVals, threebardata); barchart.setData(bardata); barchart.getLegend().setPosition(Legend.LegendPosition.ABOVE_CHART_LEFT); barchart.getLegend().setForm(Legend.LegendForm.CIRCLE);
barchart.getXAxis().setPosition(XAxis.XAxisPosition.BOTTOM); barchart.getXAxis().setDrawGridLines(false);
barchart.getAxisRight().setEnabled(false); barchart.getAxisLeft().setAxisMinValue(0.0f); barchart.getAxisLeft().setDrawGridLines(false);
barchart.setDescription("No Deal"); barchart.setDescriptionTextSize(20.f); barchart.animateXY(1000, 2000); } }
|
这里,一些使用方式可以具体去看看对应的类机构,比如BarChart
通过查看它对应的源码,可以更好的使用功能,AS会自动的帮我们反编译一些内容,能借助AS很好的学习一些开源Jar包。
在上面这个例子中,如何让现实的数值为“xxx元”呢?
MPAndroidChart中存在ValueFormatter这个东西,通过这个还做一个转换,如实现“xxx元”的效果
1 2 3 4 5 6
| bardata.setValueFormatter(new ValueFormatter() { @Override public String getFormattedValue(float v, Entry entry, int i, ViewPortHandler viewPortHandler) { return entry.getVal() + "元"; } });
|